iiiiiiiiDniiigiiiiiiiiiiiii 

US005485567A 

United States Patent [19] [in Patent Number: 5,485^67 

Banning et al. [45] Date of Patent: Jan. 16, 1996 



[54] ICONIC TABLE OF DATABASE 
INFORMATION 



[75] 



[73] 

[21] 
[22] 

[63] 

[511 
[52] 
[58] 

[56] 



Inventors: Kenneth IL Banning; George P. 
Erwin-Grotsky; Shih-Gong Li; 
Alejandro Sanchez-Frank; Theodore 
Sbrader, all of Austin, Tex. 

Assignee: International Business Machines 
Corporation, Armonk, N.Y 

Appl. No.: 3064H)2 
Filed: Sep. 15, 1994 

Related V^. Application Data 

Continuation of Set. No. 803,876, Dec. 9. 1991. 

Int CI.** „ - - G06F 15/40 

U.S. CI 395/148; 395/600 

Field of Search « 395/J48. 155, 

395/159, 160. 161. 156. 157, 158, 12. 600 

References Cited 
U.S. PATENT DOCUMENTS 



4,813,013 
4,859,187 
3.040.131 
5.134,560 
5,301,270 



3/1989 
8/1989 
8/1991 
8/1992 
2/1993 



Dunn 

Peterson 

Tbires 

Fernter et ai. 
Steinberg et al. 



... 364/900 

... 434/118 

... 364/521 

... 364/188 

... 395/161 



OTHER PUBUCATIONS 



"A Database Model for User Interface Management Sys- 
tems" Proceed of the 1990 Symposium on Applied Com- 
puting, pp. 200-201. Anderson ct al.. 6 Apr. 1990. 
"Extending a Relational DBMS to Support Complex 
Objects" 2nd Intl. Conf on Data and Knowledge Sys. for 
Manuf. and Eng. pp. 131-171, Gardarin etal, 18 Oct 1989. 



"Adding Methods to Rcl DB Constmcts", Plrocced of the 
15th Ann. Intl. Conf.. Ttaiaka ct al., pp. 42-49. 13 Sep 91. 
"Extending SQL with General Transitive Closure and 
Extreme Value Selections" 1BEE Transactions on Know, and 
Data Eng. pp. 381-390, Eder, J., Dec. 1990. 
"A Visual Query Lang, for an ER Data Model", IEEE 
Computer Society Press. 1989 IEEE Workshop on Visual 
Lang. pp. 165-170, Czejdo et al. 6 Oct, 89. 
"A Multiniedia Knowledge-Baed System", IEEE Computer 
Soc. Press, Proceed of the 15th Annual hit Comp. Software 
& Appl. Conf. Sakaguchi et al, 13 Sep. 1991. pp. 118-123. 
"Implementation of an OBJ-Orien Front-End to A Rel. 
Database Sys", IEEE TenCon '90, Kisword et al., pp. 
811-815, vol. 2, 27 Sep 1990. 

"ESQL: a Query Lang, for the Relation Model Supporting 
Image Domains", Proceed 7th Intl. Conf. on Data Engineer- 
ing , Ahad et al.. pp. 550-559, 12 Apr. 1991. 
'Toward a Multilevel Relau'onal Data Language". IEEE 
Fourth Aerospace Computer Security Applications Confer- 
ence, Lunt et al.. pp. 72-79, Dec. 16, 1988. 
Research Disclosure Mar. 1990, p. 211. Icons in the Head- 
ings of Columnar Lists. 

Research Disclosure Nov. 1989, p. 837, Iconic Fields. 

Primary Etomw^r— Robert W. BeausoHel, Jr. 

Assistant Examiner — Stephen C. Elmore 

Attorney, Agent, or Firrw— Diana L. Roberts; Lawrence K. 

Stephens 



[57] 



ABSTRACT 



A method, system and program for displaying database 
information via a table containing icons and other summary 
information which clearly and concisely convey particular 
aspects of a database to a user. The table display acts as a 
window into a database when it is selected by a user. A user 
can also make changes to the database via the window of 
information. 
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ICONIC TABLE OF DATABASE 
INFORMATION 

This is a continuation of application Ser. No. 7/803,876 
filed Dec. 9, 1991. 5 

FIELD OF THE INVENTION 

This invention goterally xelalcs to improvements in data- 
base applications and more particularly to providing con- jq 
cisc, visual information concerning table colunms and keys. 

CROSS REFERENCE TO RELATED 
APPUCATIONS 

Subject matter in the present application is related to the 1^ 
invention in U.S. patent application Ser. No. 07/803,875 
filed Dec. 6, 1991 under the liUe "ICONIC REPRESENTA- 
TION FOR TABLE COLUMNS**. 



BACKGROUND OF THE INVENTION 



20 



Databases have become the subject of significant recent 
interest, not only because of the increasing volume of data 
being stored and retrieved by computerized databases but 
also by virtue of the data relationships which can be estab- 25 
lishcd during the storage and retrieval processes. Most of the 
interest in databases has concerned users demands for an 
improved crgonomic interface to the database through inno- 
vative display technology. 

A recent innovation to improve the ergonomic interface to 30 
a knowledge-base system is disclosed in U.S. Pat No. 
4,813,013 to Dunn. The patent reveals an interactive, rule- 
based system which allows icons to be selectively tied to 
particular rule definitions. The stored rules are cross-refer- 
enced to the icon to which they pertain, so that whenever the 3S 
icon is selected by a problem solving user for use in building 
a problem solution, the rules pertaining thereto are accessed 
and applied. 

Research Disclosure, Icons in the Headings of Columnar 
Lists, March 1990 discloses another example of an ergo- ^ 
nomic advance in user interfaces for databases. This disclo- 
sure discusses a facility to allow icons to s^pear in the 
heading area of a colunmar list. For example, fields such as 
security level can have a header that is an icon and looks like 
a lock. Another Research Disclosure, Iconic Fields, Novem- 
ber 1989, discloses icons that can be selectively opened to 
reveal detailed information concerning the field and its 
contents. Then, when the user has adjusted the detailed 
information, the field can be deselected and returned to an 
icon. 50 

SUMMARY OF THE INVENTION 

Accordingly, it is a primary object of the present invention 
to provide a user with a graphical, database interface 
emptying icons and a row/colunm display to present infor- 
mation about a table and its contents; allow a user Lo 
manipulate information in the database via the icons; and 
employ the graphical interface as a vrindow into the data- 
base. 60 

These and other objects of the present invention are 
accomplished by the operation of an algorithm in the 
memory of a processor. The processor accesses data struc- 
tures to determine the current status of a database table and 
displays the information stored in the database in a graphical 65 
display. The graphical display employs a table organized, 
iccmic representation of selected information for table col- 



umns and keys. A user can also select an icon to open a 
dialog box of detailed information relating to the particular 
cohinm or key. The dialog box enables the user to directly 
view or manipulate particular aspects of the database. The 
table organized, icoruc representation provides concise, 
visual information indicating the relationships between col- 
unms and keys and visually coaches a user to select the 
appropriate information to satisfy the user's requirements. 

BRIEF DESCRIPTION OF THE DRAWINGS 

FIG. 1 is a block diagram of a personal computer system 
in accordance with the subject invention; 

FIG. 2 schematically depicts a graphic display of database 
table information in rows and columns employing icons and 
alphanumeric information in accordance with the subject 
invention; 

FIG. 3 depicts a set of data structures for creating a 
graphic display of information in accordance with the sub- 
ject invention; 

FIG. 4 depicts a set of data structures used to create a 
graphic display of information in accordance with the sub- 
ject invention; 

FIG. 5 schematically depicts a data structure used to 
create a graphic display of database information in accor- 
dance with the subject invention; 

FIG. 6 is a fiow diagram of the detailed logic in accor- 
dance with the subject invention; 

FIG. 7 is a fiow diagram of the detailed logic in accor- 
dance with the subject invention; 

no. 8 is a fiow diagram of the detailed logic in accor- 
dance with the subject invention; 

RG. 9 is a flow diagram of the detailed logic in accor- 
dance with the subject invention; and 

FIG. 10 is a fiow diagram of the detailed logic in 
accordance with the subject invention. 

DETAILED DESCRIPTION OF THE 
INVENTION 

The invendon is preferably practiced in the context of a 
relational database such as is available with Database Man- 
ager in the Extended Services (TM) software program 
available from IBM Corporation. A representative hardware 
oivironment is depicted in FIG. 1, which illusU^s a typical 
hardware coniiguralion of a workstation in accordance with 
the subject invendon having a central processing unit 10, 
such as a conventional microprocessor, and a number of 
other units interconnected via a system bus 12. The work- 
station shown in FIG. 1 includes a Random Access Memory 
(RAM) 14, Read Only Memory (ROM) 16, an I/O adapter 
18 for connecting a keyboard 24, a mouse 26. a speaker 28, 
a microphone 32, and/or other user interface devices such as 
a touch screen device (not shown) to the bus, a communi- 
cation adapter 54 for connecting the workstation to a data 
processing network and a display adapter 36 for connecting 
the bus to a display device 38. 

A control element (i.e. machine-readable medium) directs 
the operation of the workstation. Any suitable machine- 
readable medium may implement the conUX)l element, such 
as RAM 14, a magnetic diskette, magnetic tape, or optical 
disk (the last three being located in disk units 20). The 
graphical database interface of the present invention resides 
within the control element. The graphical database interface 
contains data structures and detailed logic (described 
herein), which are transmitted as "signals" recognizable by 
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the workstation. These signals incLude signals which control 
the workstation to store data in a table, read data from the 
table and summarize the information by generating icons 
representing indices to the table, and display those icons and 
data in columns and rows on display device 38. Hie work- s 
station has resident thereon the OS/2 base operating system 
and the aforementioned Database Manager relational data- 
base pTogranL The invention further contemplates that pre- 
existing queries formulated in classical SQL format be 
conveyed to the workstation and subjected to conversion 
into visual or graphical. Iconic information for display on a 
graphic display 38. The user thereafter interfaces to the 
database via the graphic display and dynamically views the 
results of any changes to the database information on the 
graphic display. Ttie reader is referred to IBM's SQL REF- 
ERENCE, S04G-1012 (1991) for a detaUed description of 
statements in the structured Query Language (SQL). Hie 
SQL REFERENCE is mcorporated by reference in its 
entirety. 

A database is a collection of information stored in a 20 
computer. The data is arranged as rows in tables, which 
represent groups of related information. A database may 
contain one or more tables. Structured Query Language 
(SQL) is an established set of statements that can be used to 
manage information that is stored in a database. By using 25 
these statements, a user can add, delete or update informa- 
tion in a table or request information from one or more tables 
in the form of a report SQL performs operations on the 
tables to access the information within them without the user 
needing to know how the data is physically stor^. 30 

Referential integrity refers to the rules that govern some 
of the relationships within a database. Referential integrity 
is enabled by adding referential constraints to table and 
column definitions of a database. A referential constraint 
defines the rules for a relationship between a parent table and 35 
a dependent table. A parent table is the table containing the 
primary key that defines the relationships with a foreign key 
in anoUier table. A table can be a parent in any number of 
relationships. 

A primary key is a column or an ordered collection of ^ 
columns whose values uniquely identify a row. To be 
unique, this collection of values carmot be duplicated in any 
other row. A primary key need not have a dependent foreign 
key. 

A foreign key is one or more columns in a table whose j^r^ 
values match the values of a primary }icy of a table. A | 
foreign key is used to establish a relationship with a primary I 
key for the purpose of enforcing referential integrity among / 
tables. A referential constraint is an assertion that non-null 
values of a foreign key are valid only if they exist as values 
of the primary key in a parent table. 

A dependent table is a table containing the foreign key 
that defines the relationship. A table can be a dependent in 
multiple relationships. 

User interfaces for database tables typically shield users 
from a complete table definition at one time. Users are given 
specific subsets of the database information to view at a 
given time, such as column definitions or the primary key 
definition. The user is not given an effective method for 
drawing relationships between the columns and keys in the 
table without opening additional windows or panels. 

The invention presents information about a database table 
in the form of icons and numbers. This gives the user a 
global sense of the structure of the various tables and helps 6S 
to enhance understanding of the implications of dropping a 
key or deleting an uncommitted column. Columns are 
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uncommitted if the table to which the column belongs has 
not been committed to the database or if the columns 
belongs to changes that were made to a table thai has not 
been committed Committed columns caimot be deleted 
from a database table. 

The invention presents the user with a list of column 
names in a single column format as depicted in HG. 2, or in 
a matrix format at the discretion of the user. The primary key 
icon is presented in the first column 150 along with the 
sequence number of the column in the primary key as a 
subscript in the lower right hand comer 151. If a primary key 
has been defined that includes a particular column name 100, 
then an icon representing a key 150 appears in the column 
corresponding to the particular column name. Similarly, if a 
foreign key has been defined that includes a particular 
column name 100, then an icon representing a foreign key 
140 is induded in the corresponding column associated with 
the foreign key for the particular column name. If no foreign 
key has been defined for a particular column name, then the 
corresponding entry for the foreign key will be left blank. 

The next entry, a number entered at 130, represents the 
number of foreign keys that have been defined for the table 
that include that particular column name. Since the number 
one appears in the column at 130, one fordgn key exists that 
includes the column named DEFT. The column icon 120 
appears in the next column. Then, in the next column, the 
coiunms sequence number 110 appears. l\\is number corre- 
sponds to the order of the column names in the particular 
table. Finally, the column name 100 appears in the last 
column. 

The icons used in HG. 2 are for representation only. Other 
icon shapes or sizes may be used. Every column has a 
colunm icon 120 and a column sequence number 110. Since 
a column can be part of more than one foreign key, the 
number of fmtgn keys 130 to which a colunm belongs is a 
separate entry. The primary and foreign key icons are easily 
distinguishable from each other by their shape and color. 
The tabular approach makes it easy for a user to scan the 
display and readily assess the characteristics of a particular 
table. 

The invention also allows a user to view the details 
concerning the definitions of a table by double-clicking on 
a particular icon with a mouse button. For example, if a user 
positions the cursor over a particular column icon 120. and 
double-clicks the mouse button, then a dialog box appears 
with detailed information relation to the colunm. Similariy, 
double-clicking on a primary key icon initiates a dialog box 
containing a list of the columns in the primary key. Double- 
clicking on a foreign key icon or the number associated with 
the icon brings up a list of the foreign keys to which the 
colunm belongs. A user selects a particular foreign key from 
the list to initiate a dialog with the specifics about the 
particular foreign key. 

DETAILED LCM3IC 

The data structures and detailed logic in accordance with 
the subject invention is set forth commencing with FIG. 3. 
A set of data structures are used to organize the information 
utilized for the subject invention. The first of the data 
structures is called Columnlist 300. Each oitry in Column- 
List has a unique name 300 and fields descriptive of the 
particular column 310. The column names are chained 
together as indicated at 300, 302, . . . 304 until a nil pointer 
304 is encountered. 

The second data structure is called IndexList 320. The 
IndexList is a collection of index names and information 
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associated with each of the index names 330. The infonna- 
tion includes chained arrays of colunm names 332, ... 334 
tnduding the order that the columns are sorted in 336. 
[ndexcs can also be represented as icons since there can be 
more than one index per table in the database. Thus, the s 
index would have a unique icon like the foreign key icon 
shown in FIG. 2 and a number of indexes that this column 
belongs to. 

The third data structure is called Primary Key List 400 in 
RG. 4, The data structure contains a list of chained elements 
defining the primary key and the columns that are associated 
with the key 410, . . . 412. FbreignKeyUst 420 is another 
data structure containing ForeignKey names 420, 422, . . . 
424 and information associated with the names 430. The 
information associated with the names includes a chained 
list of ColumnNames 432, . . . 440 associated with the 
particular ForeignKeyName 420. 

FIG. 5 is an example of a VisualClue data suucture used 
to correlate information concerning a particular table in a 
database 500. Columns are provided for Column Names ^ 
510, Column Sequence Number 520, Column Type 522, 
Column Length 524, Data Must 526, t^xt Only 530, Pri- 
mary Key Sequence number 532 and Foreign Key Total 
Number 534. The information is employed by the subject 
invention to relate various fields from an existing database ^ 
into information that can be utilized for a concise display of 
pertinent information to a user. 

The different types of icons in the subject invention 
visually indicate the sequence number of a particular column ^ 
in the primary key definition (if the colunm is used for 
defining a primary key), if a particular column is used in a 
foreign key definition, the number of foreign key definitions 
in which a particular column is involved* and the sequence 
number of a particular colunm in the table definition. Each 
entry in the VisualClue data structure 500 of FIG. 5 
describes a column of a specific database table. Column- 
Name 510, ColunmSeqNo 520, ColunmType 522, Column- 
Length 524, DataMust 526 and TextOnly 530 can be 
retrieved direcdy from the data structure. PKeySeqNo 532 is ^ 
the sequence number of a particular column in the primaiy 
key definition. If the particular column is not specified in the 
primaiy key definition, then its PKeySeqNo entry will be set 
equal to a value of NULL. The determination of PKeySeqNo 
532 for a particular column is determined by comparing its 
colunm name against the ColunmName(s) in the data struc- 
ture PrimaryKeyList. FKeylbtalNo 534 is a value indicating 
the total number of foreign key definitions in which the 
particular column is involved 

FIG. 6 is the first flow chart setting forth the detailed logic 50 
in accordance with the subject invention. Control com- 
mences with a VisualClue data structure being opened for a 
particular table in an existing database as shown in function 
block 600 and an index N t>eing initialized to one as shown 
in fimcdon block 610. A label 612 is necessary for later 55 
transfer of control logic. Then, at function block 614, N is 
used as an index into data structure ColunmList 300 of FIG. 
3 to obtain information concerning the Nth Name in the 
ColumnList 300 data structure. If the Nth Name is equal to 
the nil value in decision block 622, then all of the items in ^ 
the data structure have been processed and control is 
returned at terminal block 620. 

If the Nth Name is not equal to the nil value in decision 
block 622, then as set forth in function block 624, a new 
entry is built in VisualClue utilizing the information from the 65 
ColumnList data structure for the Nth item. Thereafter, the 
PrimaryKeyList data structure 400 of FIG. 4 is accessed 



asset forth in function block 626 and another index K is 
initialized in function block 630. A test is performed in 
decision block 632 to determine if ColumnName is equal in 
value to the Kth ColumnName value in the PrimaryKeyList 
data structure. If the values match, then PKeySeqNo is set 
equal to the index K and control passes to FIG. 7. If the 
values do not match in decision block 632, then the next 
ColunmName in the PrimaryKeyList data structure 410 of 
FIG. 4 is obtained at function block 634 and examined to 
determine if it is equal in value to a nil at decision block 636. 
If it is not, then the index K is incremented at function block 
638, and control passes to decision block 632. However, if 
the value is nil, then PKeySeqNo is set equal to zero at 
function block 640 and control is passed to FIG. 7. 

FIG. 7 is a continuation of the flow logic commencing 
witii FKeyTotalNo initialization to zero at function block 
700. Then, the ForeignKeyList file corresponding to the dau 
structure set forth in RG. 4 at 420 is accessed at function 
block 710 and the first Foreign Key name is retrieved at 
function block 712. Then, information associated with the 
first Foreign Key name is retrieved at function blocks 714 
and 716. A loop is commenced at decision block 720 to 
match the particular ColunmName. If the ColurrmName is 
identified, then the Foreign Key totals are incremented to 
reflect die match at function block 722. The next Foreign 
Key Name is retrieved at function block 734, compared to 
the rul value at 740, and if it is not equal to lul (there arc 
more foreign keys) control returns to function block 714 for 
processing the next Foreign Key value. If the nil value is 
detected, then control passes to label 612 of RG. 6 for 
further processing. 

If a match is not detected at decision block 720, then tiic 
next Colunm Name in the Foreign Key List chained list of 
names is retrieved If the next name is not equal to a nil 
value, then conUt>l passes to decision block 720 for a match 
check. If die name value is nil, tiien the next Foreign Key 
Name is retrieved at function block 734 and if it is not equal 
to die nil value at decision blodc 740, then control passes to 
function block 714. If it is equal to the lul value, then control 
flows to label 612 of RG. 6 for further processing. 

RG. 8 is a flowchart of die detailed logic in accordance 
with the subject invention. Control commences at 800 by 
displaying information concerning a particular colinnn in the 
table definition matrix or its derivatives. This processing 
conmiences by accessing the VisualOue data structure 500 
of RG. 5 as set forth in function block 810. The N index is 
set to one at function block 812. Hien, at function block 814, 
the Nth entry of the data stiucmre is retrieved and a test is 
perfartned at decision block 816 to determine if the entry is 
empty or if has a value. If the entry is empty, then control 
returns at temunation block 816. 

However, if the entry is not empty, then a column icon is 
displayed in Uie cohimn icon field on the display as indicated 
in function block 820, a colunm sequence number is dis- 
played in the column sequence number field as indicated in 
furiction block 822 and a ColunmName, Columniype, Col- 
umnLength. DataMust and TbxtOrdy entry arc filled on the 
display in function block 824. Then, at decision block 826, 
a test is performed to determine if the PKeySeqNo has a 
value of zero. If it does, then the Primary Key Icon field is 
left empty on the display as indicated in function block 828 
and control passes to function block 840. If it is not equal to 
zero, then a primary key icon is displayed with the value of 
PKeySeqNo displayed in subscript in the primary key icon 
field as set forth in function block 830 and control is passed 
via terminal 840 to RG. 9. 

RG. 9 is the detailed logic associated with displaying the 
foreign key icon and the number of foreign keys field in 
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accordance with the subject invention. Control commences 
at terminal 900 and an immediate test is performed at 
decision block 910 to determine if foreign key total number 
is equal to zero. If it is, then the foreign key icon and number 
of foreign keys field are left blank as shown in function s 
block 920, the N index is incremented at function block, 950 
and control is returned to function block 814 of RG. 8. If the 
number is not equal to zero in decision block 910, then a 
foreign key icon is displayed in the foreign key icon field as 
shown in function block 930, the number of foreign keys is lo 
displayed at function block 940, the N index is incremented 
and control is returned to function block 814 of FIG. 8. 

HG. 10 presents the detailed logic associated with 
double-clicking a mouse button at various locations on a 
display in accordance with the subject invention. Control 
commences at function block 1000 if double-click is 
detected on a column icon. Then, a dialog box is opened 
displaying the particular detailed definition of a column as 
indicated at function block 1002. Finally, control is returned 
to the application at terminal 1004. Control commences at ^ 
function block 1010 if double-click is detected on a primary 
key icon. Then, a dialog box is opened displaying the 
particular detailed definition of a primary key as indicted at 
function block 1012. Finally, control is returned to the 
application at terminal 1014. Control commences at function 
block 1020 if double-click is detected on a foreign key icon. 
Then, a dialog box is opened displaying a list of the foreign 
key names for the particular table as indicated at function 
block 102Z The user can select a particular name that from 
the list to view its detailed definition as set forth in function 30 
block 1024. Finally, control is returned to the application at 
terminal 1026. One of ordinary skill in the art will readily 
comprehend that a user can change the information via a 
dialog box and have the changes made to the database if 
allowed by the database. 35 

While the invention has been described in terms of a 
preferred embodimem in a specific system environment, 
those skilled in the ait reoogiuze that the invention can be 
practiced* with modification, in other and different hardware 
and software environments within the spirit and scope of the 
appended claims. 

Having thus described our invention, what we claim as 
new, and desire to secure by Letters Patent is: 

1. An apparams for graphically displaying on a display 
information of a plurality of vertical colimms in at least one 
table of a database, comprising: 
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(a) means for accessing a data structure in memoiy 
containing the information for each of the colunrms and 
generating icons representative of the information, 
wherein at least one of the icons represents a primary 
key having values uniquely identifying a single hori- 
zontal row of the plurality of vertical columns in the 
table; 

(b) means for displaying the icons on the display; and 

(c) means for pladng alphanumeric representations of the 
information on the display, wherein at least one alpha- 
numeric representation represents a number of the 
foreign keys that one of the columns belongs to. 

2. An apparatus as recited in claim 1, wherein a second 
icon represents a foreign key. 

3. An apparatus as recited in claim 1, wherein the icons 
change based on changes to the information. 

4. An apparatus as recited in claim 1, including means for 
placing a second alphanumeric representation of the infor- 
mation on the display, wherein the second alphanumeric 
representation represents a column sequence immbcr. 

5. A method for graphically displaying information of a 
plurality of vertical columns of a database table on a display, 
comprising the steps of: 

(a) accessing a data structure contairuDg the information 
for each of the columns in the table and generating 
icons representative of the information, wherein at least 
one of the icons represents a primary key having values 
uniquely identifying a sin^e horizontal row of the 
plurality of vertical columns in the table; 

(b) displaying the icons on the display; and 

(c) placing alphanumeric representations of the informa- 
tion on the display, wherein at least one alphanumeric 
representation represents a number of the foreign keys 
that one of the column belongs to. 

6. A method as recited in claim 5. including the step of 
changing the icons based on changes to the information. 

7. A method as recited in claim 5, including the step of 
accessing information in the data structure and placing a 
second alphanumeric representation of the information on 
the display, wherein the second alphanumeric representation 
represents a column sequence number. 
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